$(function () {
    var contact_datagrid = $("#contact_datagrid");
    var contact_dialog = $("#contact_dialog");
    var contact_form = $("#contact_form");

    //给 a链接统一绑定事件
    $("a[data-cmd]").click(function () {
        var methodName = $(this).data("cmd");
        //调用方法
        methodObj[methodName]();
    });

    contact_datagrid.datagrid({
        url: '/contact/query.do',
        fit: true,
        fitColumns: true,
        columns: [[
            {field: 'name', title: '姓名 ', width: 80},
            {field: 'sex', title: '性别', width: 80,
                formatter: function (value) {
                    return value ? '男' : '<span style="color: red">女</span>'
                }},
            {field: 'birthday', title: '生日', width: 80},
            {
                field: 'school',
                title: '所属学校',
                width: 80,
                formatter: function (value) {
                    return value.name
                }
            },
            {field: 'schoolDept', title: '学校部门', width: 80},
            {field: 'job', title: '职务', width: 80},
            {field: 'tel', title: '联系电话', width: 80},
            {field: 'qq', title: 'QQ', width: 80},
            {field: 'mail', title: '邮箱', width: 80},
            {
                field: 'contact',
                title: '是否主联系人',
                width: 80,
                formatter: function (value) {
                    return value ? '是' : '否'
                }
            },
            {field: 'info', title: '备注', width: 80}
        ]],
        toolbar: '#contact_toolbar',
        singleSelect: true,
        rownumbers: true,
        pagination: true
    });

    contact_dialog.dialog({
        title: '新增联系人',
        width: 350,
        height: 420,
        closed: true,
        resizable: false,
        buttons: [
            {
                text: '保存',
                iconCls: 'icon-save',
                handler: function () {
                    methodObj.save();
                }
            },
            {
                text: '取消',
                iconCls: 'icon-cancel',
                handler: function () {
                    methodObj.cancel();
                }
            }
        ],
        //清空表单数据
        onClose: function () {
            contact_form.form('clear');
        }
    });

    //使用一个对象来统一管理实践的方法
    var methodObj = {
        add: function () {
            //弹出表格窗口
            contact_dialog.dialog("open")

            //设置标题
            contact_dialog.dialog('setTitle', '新增联系人');
        },
        edit: function () {
            //判断是否选中了数据
            var row = contact_datagrid.datagrid('getSelected');
            if (!row) {
                //如果没有选中 提示框提示信息
                $.messager.alert("温馨提示", "请选中一条数据", "warning");
                return;
            }

            //处理学校名称数据
            row["school.id"] = row.school.id;

            //选中了一条数据 回显表单数据(根据同名匹配原则 row对象中的属性名要与form中name相同才可以回显)
            contact_form.form('load', row);

            //弹出表格窗口
            contact_dialog.dialog("open");

            //设置标题
            contact_dialog.dialog('setTitle', '编辑联系人');
        },
        //保存操作
        save: function () {
            //提交表单
            contact_form.form('submit', {
                url: '/contact/saveOrUpdate.do',
                success: function (data) {
                    //转换为json对象
                    data = $.parseJSON(data);
                    if (data.success) {
                        //提示用户操作结果
                        $.messager.alert('温馨提示', '保存成功!', 'info', function () {
                            //关闭弹出框
                            methodObj.cancel();
                            // load 加载和显示第一页的所有行
                            contact_datagrid.datagrid('reload')
                        })
                    } else {
                        $.messager.alert('温馨提示', '保存失败!', 'error')
                    }
                }
            })
        },
        //取消操作
        cancel: function () {
            contact_dialog.dialog('close');
        },
        //删除联系人
        remove: function () {
            //判断是否选中了数据
            var row = contact_datagrid.datagrid('getSelected');
            if (!row) {
                //如果没有选中 提示框提示信息
                $.messager.alert("温馨提示", "请选中一条数据", "warning");
                return;
            }
            //弹出确认框 确认改变状态
            $.messager.confirm('确认', '确认要删除该联系人吗?', function (r) {
                if (r) {
                    //发送请求到后台
                    $.get("/contact/delete.do", {id: row.id}, function (data) {
                        if (data.success) {
                            $.messager.alert('温馨提示', '删除成功', 'info', function () {
                                //刷新当前页面
                                contact_datagrid.datagrid('reload');
                            });
                        } else {
                            $.messager.alert('温馨提示', '删除失败', 'error');
                        }
                    })
                }
            })
        },
        reload: function () {
            //刷新当前界面
            location.reload();
        },
        //高级查询操作
        query: function () {
            //获取查询条件的值
            var keyword = $("#keyword").textbox("getValue");
            var schoolId = $("#schoolId").combobox("getValue");

            contact_datagrid.datagrid('load', {
                //发送额外的参数
                keyword: keyword,
                schoolId: schoolId
            })
        },
        //导出文件操作
        exportXls: function () {
            //获取查询条件的值
            var keyword = $("#keyword").textbox("getValue");
            var deptId = $("#deptId").combobox("getValue");

            var url = "/contact/exportXls.do?"+ "keyword=" + keyword + "&" + "beginDate=" + beginDate +
                "&" + "endDate=" + endDate + "&" + "deptId=" + deptId;
            //打开下载窗口
            window.open(url);
        }
    }
});